package com.guomei.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.guomei.bean.Certificate;
import org.apache.ibatis.annotations.Param;

import java.util.List;

public interface CertificateMapper extends BaseMapper<Certificate> {
    /**
     * 插入证书记录
     * @param certificate 证书对象
     * @return 影响行数
     */
    int insert(Certificate certificate);

    /**
     * 根据ID查询证书
     * @param id 证书ID
     * @return 证书对象
     */
    Certificate selectById(Long id);

    /**
     * 根据用户ID和考试ID查询证书
     * @param userId 用户ID
     * @param examId 考试ID
     * @return 证书对象
     */
    Certificate selectByUserIdAndExamId(@Param("userId") Long userId, @Param("examId") Long examId);

    /**
     * 根据证书编号查询证书
     * @param certNo 证书编号
     * @return 证书对象
     */
    Certificate selectByCertNo(String certNo);

    /**
     * 查询所有证书
     * @return 证书列表
     */
    List<Certificate> selectAll();

    /**
     * 根据用户ID查询证书列表
     * @param userId 用户ID
     * @return 证书列表
     */
    List<Certificate> selectByUserId(Long userId);

    /**
     * 更新证书信息
     * @param certificate 证书对象
     * @return 影响行数
     */
    int update(Certificate certificate);

    /**
     * 根据ID删除证书
     * @param id 证书ID
     * @return 影响行数
     */
    int deleteById(Long id);

    List<Certificate> selectByCondition(Certificate certificate);

    int selectByIdCount(Long userId);
}
